<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>3_props的简写方式</title>
</head>
<body>
  <!--准备好一个 div-->
  <div id="test1"></div>
  <div id="test2"></div>
  <div id="test3"></div>

  <!--引入 react 核心库-->
  <script type="text/javascript" src="../js/16.8.4/react.development.js"></script>
  <!--引入 react-dom 用于支持 react 操作 DOM-->
  <script type="text/javascript" src="../js/16.8.4/react-dom.development.js"></script>
  <!--引入 babel 用于将 jsx 转为 js-->
  <script type="text/javascript" src="../js/16.8.4/babel.min.js"></script>
  <!--引入pro-types，用于对组件标签属性进行限制-->
  <script type="text/javascript" src="../js/16.8.4/prop-types.js"></script>

  <script type="text/babel">
    // 创建组件
    class Person extends React.Component{

      constructor(props) {
        // 构造器是否接收props，是否传递给super，取决于：是否希望在构造器中通过this访问props
        console.log(props)
        super(props)
      }

      // 对标签属性进行类型、必要性的限制
      static propTypes = {
        // 限制name必传，且为字符串
        name: PropTypes.string.isRequired,
        // 限制sex为字符串
        sex: PropTypes.string,
        // 限制age为数值
        age: PropTypes.number,
      }

      // 指定默认标签属性
      static defaultProps = {
        // 指定sex默认值
        sex:'不男不女',
        // 指定age默认值
        age:18
      }

      render(){
        // console.log(this)
        const {name,age,sex} = this.props
        // props是只读的
        return (
            <ul>
              <li>姓名：{name}</li>
              <li>性别：{sex}</li>
              <li>年龄：{age+1}</li>
            </ul>
        )
      }
    }

    // 渲染组件到页面
    ReactDOM.render(<Person name="jerry"/>,document.getElementById('test1'))
  </script>
</body>
</html>
